草庐IT

c++ - 小数位数之和

全部标签

c++ - 删除 char* 进行字节转换

每次读取文件时,我都尝试使用不同长度的字节来读取二进制文件。获得值后,我尝试将字节转换为char*。我创建了一个简单的代码如下://ThiscodeiscompiledinVisualStudio2010typedefunsignedcharBYTE;BYTE*s;s=newBYTE[3];//Iread2bytesfromthefile,Iadd+1toreserveNULLs[0]='a';s[1]='b';s[2]=NULL;//justanexampleIget2bytesfromfilechar*b;b=newchar(sizeof(s));strcpy(b,(char*)s

c++ - 计算 pi 的位数

我已经使用GMP库和C++编写了Gauss-Legendre算法的实现代码来计算pi的位数。它有正确的输出,但问题是我不知道输出在哪一点“变坏”,因为我必须在代码中指定精度。这是使用64位精度的输出:3.141592653589793238*35*,最后两位数字不正确。我的问题是,如果我想要pi的n位,b的精度是多少,算法的迭代次数是多少i需要吗?谢谢 最佳答案 Gauss-Legendre算法(又名AGM算法)要求全程精确。与牛顿法迭代不同,AGM迭代不能self纠正。因此,您从一开始就需要完全精确。此外,您还需要额外的保护数字。

c++ - 伪装的指针算术 &(array[0])

今天浏览了一些源码(是一个说明软件框架使用的示例文件),发现了很多这样的代码:int*array=newint[10];//ormalloc,whocares.Please,nolanguagewars.Thisisapplicabletobothlanguagesfor(int*ptr=&(array[0]);ptr所以基本上,他们已经完成了“获取位于地址array+x的对象的地址”。通常我会说,这简直是愚蠢,因为直接编写array+0或array+9也是一样的。我什至总是将此类代码重写为size_tfor循环,但这是风格问题。但是过度使用它让我开始思考:我是漏掉了一些显而易见的东西

c++ - C++ 中的 fprintf 和 vfprintf 有什么区别?

这个问题不太可能帮助任何future的访问者;它只与一个小的地理区域、一个特定的时间点或一个非常狭窄的情况有关,这些情况并不普遍适用于互联网的全局受众。为了帮助使这个问题更广泛地适用,visitthehelpcenter.关闭9年前。我无法找到以下问题的答案,而且我有一些与功能相关的问题。我的主要编程是用C#完成的,在学习的时候并没有真正学过C++,但在我现在的工作中我也必须做一些C++编程。大部分C++编程都是由一位前雇员完成的,他制作了一个日志记录功能。偶尔这个函数会导致错误(访问冲突)——这不会向用户显示,但我在通过调试器运行代码时看到了它。当错误发生时它指向这行代码:vfpri

c++ - C 代码中的 C4201 警告

此警告会在运行时产生任何问题吗?ext.h(180):警告C4201:使用了非标准扩展:无名结构/union 最佳答案 这是当你有一个没有名字的union或结构时,例如:typedefstruct{union{inta;intb;};//nonameintc;}MyStruct;MyStructm;m.a=4;m.b=6;//overwritesm.am.c=8;它允许您像访问结构成员一样访问union成员。当您为union命名(这是标准要求的)时,您必须改为通过union名称访问a和b:typedefstruct{union{in

c++ - (void)变量的意义

这个问题在这里已经有了答案:关闭9年前。PossibleDuplicate:Whatdoesvoidcastingdo?我刚刚浏览了一个项目,发现了这个//Thisisina.cppfile#ifxxx==5(void)var;#endif这个(void)var有什么作用?这样做有什么意义。我听说这与编译有关。添加c和cpp标签以防这种情况很常见。

c++ - 在 C 和 C++ 中为 NULL/false 大于 0x0/0b0/'\0'/0

这个问题在这里已经有了答案:WhatisthedifferencebetweenNULL,'\0'and0?(11个答案)关闭9年前。如问题中所述,我一直在将NULL和false(在C++中)与0或0x0等互换使用。我很好奇,除了作为0的同义词之外,它们是否具有任何特殊含义。

c++ - 设置整数的位数

这个问题在这里已经有了答案:PrintleadingzeroswithC++outputoperator?(6个答案)关闭9年前。在C++中有没有一种方法可以使编译器采用一定数量的数字,即使它们的第一个数字是0。例如:我有一个项目编号是00001,当我从文件中导入编号时它显示1。我希望它导入所有五位数字并显示为00001。我真的没有要显示的代码,因为我什至不知道为此使用什么函数,而且我拥有的代码正如宣传的那样工作,这不是我想要的。我可以将数字设为字符串,但我更愿意将其设为整数。

c++ - C++ 中 100 位数字的平方根

'unsignedlonglong'最多可以求解15位数字。有没有办法找到100位数字的平方根? 最佳答案 您还可以使用Boost.Multiprecision库。这个库为一些流行的多精度实现提供了包装器。#include#include#include#includeintmain(){std::strings(100,'0');s.at(0)='1';boost::multiprecision::mpfr_float_100f(std::move(s));boost::multiprecision::mpfr_float_100

c# - 为什么要在 char 上使用定界符?基于c的

前几天我在用C#编写一些代码,这让我开始思考。如果char文字只能有1个字符(或定界字符),那么为什么我们需要结束定界符?比如目前我们需要这样写:charcharacter='s';而且在任何情况下(显然)这都行不通:charcharacter='sa';那为什么我们要结束'而不是暗示呢?例如:charcharacter='s;charanotherCharacter='\';可读性只会受到影响,因为我们已经习惯了当前的标准(不一定是因为这种方式的可读性较差)。 最佳答案 这是约定在这个unicode世界中,字符不一定表示为一个字符